<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <title>Document</title>
  <script src="https://cdn.jsdelivr.net/npm/vue@2.7.10/dist/vue.js"></script>
</head>

<body>

  <div id="app">
    <!-- 如果ref写在组件上，就是为了获取组件实例 -->
    <!-- 只要得到了组件实例，就可以获取数据，调用方法 -->
    <ml-a ref="mla"></ml-a>
    <button @click="fn">访问a组件</button>
  </div>

  <script>
    // 一个组件也是一个对象，对象也叫实例
    // vue内部会帮我们new一个组件实例
    Vue.component("ml-a", {
      template: `
                <div>
                    <div>我是ml-a组件</div>
                </div>
            `,
      data() {
        return {
          a: 1, b: 2
        }
      },
      methods: {
        fn() {
          console.log("fn...");
        }
      },
    })
    
    // vm叫根组件实例
    let vm = new Vue({
      el: "#app",
      methods: {
        fn() {
          // this.$refs.mla 得到组件实例。
          console.log(this.$refs.mla.a);
          console.log(this.$refs.mla.b);
          this.$refs.mla.fn()
        }
      }
    });
  </script>

</body>

</html>